import { Toast } from "antd-mobile";
import axios from "axios";

export const request = axios.create({
  baseURL: "/api",
  timeout: 10000,
  headers: { "X-Custom-Header": "foobar" },
});

// 添加请求拦截器
request.interceptors.request.use(
  function (config) {
    // 开启laoding
    Toast.show({
      icon: "loading",
      content: "数据加载中...",
      duration: 0,
    });
    // 在发送请求之前做些什么
    return config;
  },
  function (error) {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

// 添加响应拦截器
request.interceptors.response.use(
  function (response) {
    // 结束laoding
    Toast.clear();
    // 2xx 范围内的状态码都会触发该函数。
    // 对响应数据做点什么
    return response;
  },
  function (error) {
    // 结束laoding
    Toast.clear();
    // 超出 2xx 范围的状态码都会触发该函数。
    // 对响应错误做点什么
    return Promise.reject(error);
  }
);
